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BACKGROUND OF THE INVENTION 

Field of the Invention 

This invention relates to a process to store an electronic program guide in a 
television set-top receiver. 

Description of the Related Art 

Consumers have several options to access television programming. 
Conventional broadcasts are available in most areas, but random electronic signals 
interfere with reception of these analog signals. The Federal Communication 
Commission has ruled that analog signals may not be broadcast after 2006. Many 
commercial service providers broadcast a wider selection of programming than 
conventional analog broadcasters. But commercial cable service providers are limited 
to a geographic areas with sufficient population to support the required investment in 
infrastructure. Satellite transmission of signals provides numerous channels, hence 
selection, over a wide geographic area. 

Satellite and cable transmissions typically incorporate more channels than a 
conventional television will receive. Digital signals are broadcast in Moving Picture 
Expert Group (MPEG) format that cannot be displayed without being decoded. The 
service provider typically supplies and installs a set-top receiver to decode the MPEG 
signal and allow access all to channels and services made available by the provider. 

For example, the service provider may encode certain signals, or programs, 
and make these selected programs available only on a pay-per-showing agreement. 
The set-top receiver incorporates a feature allowing the consumer to view an encoded 
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program. After the consumer agrees to pay for the encoded program, the set-top 
receiver transmits the request, receives the coded program and decodes the signal. 

In addition to pay-per-view events, programming may include sports events, 
musical events, live music and network broadcasts. A service provider's set-top 
receiver will download a program of these events (electronic program guide or EPG) 
and make this guide available to the viewer. The EPG will list the date, channel and 
time for each upcoming event. 

A typical set-top receiver has a central processing unit (CPU) and a return 
channel. Recently manufactured set-top receivers have more powerful CPUs, faster 
return channels, and are capable of supporting interactive multimedia applications. 
Newer set-top receivers have more memory and typically include a hard drive. 

The CPU performs various functions, including initializing the hardware 
components, retrieving data and instructions from memory and running various 
programs. Many set-top receivers depend on internal random access memory (RAM) 
as a temporary storage for instructions transmitted to the set-top receiver by the CPU. 
RAM is generally, one of two types, dynamic random access memory (DRAM) and 
static random access memory (SRAM). 

An EPG is downloaded at least once per day, typically at midnight. Service 
providers can also update an EPG on an hourly basis, or provide hourly updates of 
selected EPG information. Information contained in an EPG assists the viewer in 
searching for preferences and allows the viewer to make an informed choice. For 
example, if a viewer prefers John Wayne movies, the EPG will provide information 
regarding the dates, times and channels of upcoming John Wayne movies. As EPG 
functions expand, memory requirements increase. 

An EPG will typically be stored in the set-top receiver in DRAM. DRAM is 
also used by other components of the set-top receiver such as the CPU, the decoder 
and graphics functions. Access to information stored in DRAM is rapid when 
compared to information stored on a hard disk where access to the stored information 
is sequential, rather than random. However, DRAM is more expensive to 
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manufacture and install. Consequently, a need exists to reduce the amount of DRAM 
necessary to store an EPG in a set-top receiver while maintaining the speed of access. 

SUMMARY OF THE INVENTION 

The present invention partitions the EPG, allowing storage of portions of the 
5 EPG in separate memory components. Based on viewer preferences, the invention 
identifies preferred portions of the EPG and stores these portions in the more rapid 
memory. The more rapid memory can be electronic, or RAM. The invention 
partitions the EPG into at least three portions: the channel portion, the schedule 
portion and the program portion. The invention further divides each portion into a 

10 subportion (or submodule) including only preferred data. The invention updates the 
information stored in the memory module having the most rapid access. The 
invention also detects infrequently accessed portions of the EPG stored in the most 
rapid memory and moves the infrequently accessed portions to memory with slower 
access. The memory with slower access can be magnetic, or a hard drive. Storing 

15 only preferred portions of a program guide in memory having rapid access maintains 
the speed of access to the preferred portions of the EPG and increases the amount of 
available memory with rapid access. 

The foregoing is a summary and thus contains, by necessity, simplifications, 
generalizations and omissions of detail; consequently, those skilled in the art will 
20 appreciate that the summary is illustrative only and is not intended to be in any way 



BRIEF DESCRIPTION OF THE DRAWINGS 

The present invention may be better understood, and its numerous objects, 
features, and advantages made apparent to those skilled in the art by referencing the 
25 accompanying drawings, in which the use of the same reference symbols in different 
drawings indicates similar or identical items and in which: 

Fig. 1 is a block diagram showing the components of a typical set-top 

receiver. 

Fig. 2 is a block diagram showing the related art of storing an EPG. 



limiting. 
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FIG. 3 is a block diagram of the present invention showing an EPG partitioned 
and stored in separate memory modules. 

Fig. 4 is a flow diagram showing updating the information stored in the first 
memory device with information moved from the second memory device. 

The use of the same reference symbols in different drawings indicates similar 
or identical items. 

DETAILED DESCRIPTION 

The following is intended to provide a detailed description of an example of 
the invention and should not be taken to be limiting of the invention itself. Any 
number of variations may fall within the scope of the invention, which is defined in 
the claims following the description. 

The present invention is a process to partition and store an EPG. The 
invention periodically downloads an EPG from a service provider. The invention is a 
mechanism to identify the preferred portions of the EPG and to store those portions in 
a segment of memory having rapid access. The memory used to stored the preferred 
portions of the EPG can be electronic or DRAM. The remainder of the EPG is stored 
in a separate memory segment having less rapid access. The memory segment used to 
store the remainder of the EPG can be magnetic or a hard disk. 

A mechanism is provided that updates portions of the EPG stored in the 
memory module with the most rapid access. Based on viewer queries, the mechanism 
detects and identifies the portions of the EPG containing frequently accessed, or 
preferred, data. Preferred portions of the EPG stored in memory with more rapid 
access are moved to memory with slower access, to increase the available memory to 
store data preferred by the user. Similarly, portions of the EPG containing preferred 
data are moved to memory having more rapid access from memory having slower 
access. 

Set-top receivers typically have several interfaces, including: high-speed 
multimedia interfaces, modems, RS 232 ports, TV/VCR interfaces, remote controls 
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and IR blasters. Set-top receivers communicate with televisions and video recorders 
through output ports that typically are specific to individual vendor's products. High- 
speed multimedia interfaces allow communication with devices such as camcorders 
and Digital Video Devices (DVDs). 



facilitates interactive services. Modems are used to send requests to servers on the 
Internet, enable users to send email and other services such as video-on-demand. The 
Multimedia Cable Network System (MCNS) has developed a standard for 
communications by a modem over a cable network. The standard, called Data Over 
10 Cable System Interface Specification (DOCSIS) allows Internet services to be offered 
to PC users through a digital television modem. 

A remote control or IR blaster may be used to change channels on the set-top 
receiver. A remote control may also execute an EPG navigational system and start an 
installation menu for configuring the set-top receiver. An IR blaster allows a user to 
15 control a television and set-top receiver from rooms other than the room in which the 
television and set-top receiver are located. An IR blaster transmits a signal 
compatible with a remote control connects directly to a set-top receiver. 

A set-top receiver incorporates an operating system (OS) which allows the 
unit to function. Operating systems allocate and control the use of the CPU, control 

20 data transfers, manage computer memory, control communications between 

computers and manage file systems and data storage. The kernel layer of an operating 
system is stored in read only memory ("ROM") and will be loaded first when the 
system is switched on. The kernel allows a set-top receiver to simultaneously execute 
different sections of a program. A layer identified as a loader is also included in a set- 

25 top receiver. The loader allows the user to download programs built into the memory 
of the set-top receiver. 

A typical OS also includes software drivers to control hardware peripherals. 
Finally, a set-top receiver operating system includes Application Program Interfaces 
(API's) specific to a set-top operating system environment. API's are necessary to 
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write applications for a specific operating system. Both OS and the API are 
transparent to the user. 

Fig. 1 is a block diagram illustrating an example architecture of a set-top 
receiver. In this example, satellite dish 110 receives a signal from the service 
5 provider. The signal is transmitted to tuner module 120 containing broadcast in-band 
tuner 121 and out-of-band tuner 122. Broadcast in-band tuner 121 isolates a channel 
from a multiplex of channels and converts the channel to baseband. Out-of-band 
tuner 122 is used to facilitate transfer of data between the service provider and the set- 
top receiver. Out-of-band tuner 122 is also used to provide consumers with 

10 interactive services. Tuner module 120 also contains return path 123, allowing the 
' user to send data to the service provider. Modulator 112 converts the incoming signal 
to digital and delivers the modulated signal to return path 123. From tuner 120, the 
signal is conveyed in MPEG (or other format) to demodulator 130. Demodulator 130 
converts the analog signal to a digital bit stream containing at least video and audio 

15 signals. Demodulator 130 transmits the signal to transport demultiplexer 140. 

Transport demultiplexer 140 conveys the signal to audio decoder 145, video decoder 
150 and data decoder 160. Audio decoder 145 conveys the audio signal to speaker 
147. Video decoder 150 transmits the signal to graphics processor 160 that sends the 
signal to monitor 170. Data decoder 160 sends the signal to a system bus, in this 

20 example 32 bit system bus 172. System bus 172 is electronically coupled to hard 
drive 174 and incorporates data ports, including RS-232 port 176, USB port 178, 
modem port 180 and television/video out port 182. System bus 172 is also coupled to 
SRAM 184, DRAM 186, FLASH memory 190 and EEPROM memory 192. Finally, 
system bus 180 is electronically coupled to CPU 188. 

25 Figure 2 depicts storage of the complete EPG in DRAM. At least three 

modules are stored for up to 14 days of programming: program information 210, 
channel information 220 and schedule information 230. In addition, descrambling 
information 240 and other EPG information 250 may be stored. 



30 program information 302, channel information 304 and schedule information 306 are 
stored in a rapid access memory module. This embodiment of the invention uses 



Figure 3 illustrates an embodiment of the present invention. Preferred 
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DRAM as the rapid access memory module and a hard drive as the separate memory 
module. The present invention also has the capacity to store other EPG information 
308 with the preferred program information 302, channel information 304 and 
schedule information 306. Figure 3 depicts the remaining program information 312, 
5 channel information 314, schedule information 316 and other EPG information 318 
stored on a second memory device. Figure 3 further depicts updates 320 and 330 of 
the preferred information as further illustrated in Figure 4. 

Figure 4 depicts a selection algorithm to select and maintain the contents of 
the EPG in the separate memory components. Periodically, typically at midnight each 

10 day, EPG data is downloaded in event 420 from the signal transmitted by the service 
provider. The daily download of EPG information is initially stored in event 430 on 
the hard disk. In event 450, the algorithm searches the downloaded EPG for a match 
with programs, channels and schedules preferred by the individual user. In event 470, 
if the algorithm finds a match the algorithm stores the matching data on the rapidly 

15 accessed memory module. If the service provider transmits updated EPG during the 
day the algorithm also searches the updated information for a match, as described 
below. 

Preferred programming 440 is determined from the following information 
entered by the user(s): five most frequently viewed channels 442, five most viewed 

20 programs 444, five most viewed program types 446 and the five most viewed time 

slots 448. The five most frequently viewed channels 442, five most viewed programs 
444, five most viewed program types 446 and the five most viewed time slots 448 
constitute preferred data. If the EPG is updated, the algorithm searches, in event 460, 
the updated information for a match with viewer preferences. If a match is found 

25 between upcoming programming and viewer preferences, the information stored in 
the most rapid access memory is adjusted, in event 480. 

While particular embodiments of the present invention have been shown and 
described, it will be obvious to those skilled in the art that, based upon the teachings 
herein, changes and modifications may be made without departing from this invention 
30 and its broader aspects, and therefore, the appended claims are to encompass within 
their scope all such changes and modifications as are within the true spirit and scope 
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of this invention. Furthermore, it is to be understood that the invention is solely 
defined by the appended claims. 
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